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DATA ACQUISITION NETWORKS WITH NMOS AND CMOS 



LSI technology is making it easier and less expensive to 
design and build complex electronic systems. This fact 
holds true for Data Acquisition Networks (DANs) due to 
the new single chip A/Ds and microprocessor systems. 
Thus, it is now feasible to build your own data acquisition 
network instead of buying a completed system, and there- 
by save money. 

This article discusses an eight-channel DAN using the 
Motorola MCI 4433 CMOS A/D converter and the M6800 
microprocessor. The number of channels can be expanded 
or reduced very simply. In addition to the eight channel 
DAN the program for a single channel system is ^own. 
The inputs to the system, positive or negative pokuity, are 
multiplexed with a CMOS analog multiplexer. 

MC14433 A/D CONVERTER 

The MC14433 is a single chip 3^ digit A/D converter 
using a modified dual ramp technique of A/D conversion. 
Housed in a 24 pin package it features auto-polarity, auto- 
zero and a high input impedance. Figure 1 shows the pin 
diagram of tiie MC 14433. 

The output of the MC 14433 is 3^/i digit multiplexed 
BCD with the MSD containing iiot^nly the half digit but 
also polarity of the ii^t, ovenaiige and imdernuige 
infxHrmation. Figure 2 describes the decoding for the MSD. 
Tlie digit selects for the multiplexed BCD have interdigit 
blanking to ensure correct BCD data during the time that 
the digit select is true. 

The A/D converter is ratiometric and requires an ex- 
ternal reference voltage. This reference voltage is 2.000 
volts for the 1 .999 vdt range and 200 mV for a 199.9 mV 



ftill scale input. Both the unknown and reference inputs 
and analog ground are high impedance inputs. Other 
external components required are clock resistor, inte- 
grator resistdir and capacitor, and offset capacitor. Predsifm 
components are not required. 

Of particular interest for the data acquisition systems 
are the display update (DU) and the end of conversion 
(EOC) pins. The EOC pin indicates the end of one conver- 
sion cycle and the start of the next conversion by a posi- 
tive pulse one-half clock period long. The display update 
pin is an input to the chip which allows the data to be 
strobed into the output latches. If at least one positive 
edge is received prior to the ramp down cycle, new data 
is strobed to the display. In a stand alone A/D system, 
EOC is coimected to DU. 

Also of significance to the data acquisition network is 
the input polarity detection sequence for the MC14433. 
Polarity for tiie current conversion cycle is determined in 
the previous conversion cycle. Thus if the polarity is 
reversed, a second conversion cycle must be made in order 
to obtain a correct measurement. 

The MC 14433 requires two power supplies. The total 
voltage across the device must not exceed 18 volts. Pin 13 
is the refi^ence level for the output circuitry of the 
MC14433. If this pin is tied to volts, the BCD output, 
digit select and EOC will swing from volts to Vjjq. If 
however, pin 13 is tied to V^^, the output swing wM be 
fromVgg toVoo- 

The clock for the MC 14433 is internal to the chip, 
requiring only a single external resistor to set the fre- 
quency. A^xtemal clock may be used by driving pin 10. 
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FIGURE 1 - MC14433 Pin Assignment 



Circuit diagrams external to Motorola products are included as a means of illustrating typical semiconductor applications; consequently, 
complete Information sufficient for construction purposes Is not necessarily given. The information In this Application Note has been care- 
fully checked and Is believed to be entirely reliable. However, no responsibility Is assumed for Inaeeuraeles. Furthermore, such Inforntatlon 
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Notes for Truth Table 

Q3 - 14 digit, low for "1 ", high for "0" 

Q2 — Polarity: "1 " = positive, "0" = negative 

QO — Out of range condition exists If QO = 1. When uspd in 
conjunction with Q3 the type of out of range condition 
Is indicated, i.e., Q3 = — OR or Q3 = 1 — UR. 

When only segment b and c of the decoder are connected 
to the Yi digit of the display, 4, 0, 7 and 3 appear as 1 . 

FIGURE 2 - MSD Coding 

The total conversion time for the MC14433 is approxi- 
mately 16400 clock periods. This conversion time includes 

the auto-zero cycle and the unknown input measurement 
cycle. The clock frequency may be operated up to about 
400 kHz producing a conversicm time of 40 ms. 

MPU 

Tt» Motorola micrdprocessor syist^ devices used are 
the MC6800 MPU, MCM6810 RAM, MCM6830 ROM and 
MC6820 PIA (peripheral interface adapter). The following 
is a brief i description of the basis system as it per^ 
tains to flie A/D systems presented later in this applica- 
tion note. 

The Motorola MPU system uses a 16>bit address bus and 

an 8-bit data bus. The 16-bit address bus provides 65,536 
possible memory locations which may be either storage 
devices (RAM, ROM, etc.) or interface devices (PIA, etc.). 
The basic MPU contains two 8-bit accumulators, one 16-bit 
index register, a 16-bit program counter, a 16-bit stack 
pointer, and an 8-bit condition code register. The condition 
code register indicates carry, half carry, interrupt, zero, 
minus, and 2's complement overflow. Figure 3 shows a 
functional block of the MC6800 MPU . 

The MPU uses 72 instructions with six addressing 
modes which provide 197 different operations in the MPU. 
A summary of each instruction and function with the 
appropriate addressing mode is shown in the MC6800 
data sheet. 

The RAMs used in the system are static and contain 
128 8-bit words for scratch pad memory while the ROM is 
mask programmable and contaMs 1024 8-bit words. The 
ROM and RAM, along with the remainder of the MPU 
system components, operate from a single +5 volt power 
supply; the address bus, data'- bus- and PiAs are TTL 
compatible. 

The MPU system requires a 20 non-overlapping clock 
sudi as the MG687S* with a lower frequency limit of 100( 
kHz and an upper limit of 1 MHz. 
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FIGURE 3 - MPU Pin, funetiom 

The PIA is the interface device used between the address 
and data buses and the analog sections of the A/D. Each 
PIA contains two essentially identical 8-bit interface ports. 
These ports (A side, B side) each contain three internal 
registers that include the data register which is the inter- 
face from the data bus to the A/D, the data direction regis- 
ter which programs each of the eight lines of the data 
register as either an input or an output, and the control 
register which, in addition to other functions, switches the 
data bus between the data register and the data direction 
register. Each port to the PIA contains two addition pins, 
CAl and CA2, for interrupt capabiUty and extra 1/0 lines. 
The functions of these lines are programmable with the 
remaining bits of the control register. Figi^ie 4 shows a 
functional block of the MC6820 PIA. 

Each PIA requires four address locations in memory. 
Two addresses access either of the two (A or B sides) data/ 
(iata'dlrectioh registers while the remaining two addresses 
access either of the two control registers. These addresses 
are decoded by the chip select and register select lines of 
the PIA which are connected to the MPU address bus. 
Selection between the data register and data direction 
register is made by programming a "1" or "0" in the third 
least significant bit of each control register. A logic "0" 
accesses the data direction register whUe a lo^c "1" 
accesses the data register. 

By programming "0"s in the data direction register each 
corresponding line performs as an input, while "T's in the 
data direction register make corresponding lines act as 
outputs. The eight lines may be intermixed between inputs 
and outputs by piopaoiniiag ^^IMm^ emMm'&sm^ 
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FIGURE 4 - 

"l"s and "0"s into the data direction register. At the 
begjiming of the program the I/O configuration is pro- 
granuned into the data direction register, after which the 
control register is programmed to select the data register 

for I/O operation. 

8-CHANNEL DATA ACQUISITION NETWORK 

Figures 5 and 6 are the flow diagram for the 8-charmel 
data acquisition network. Figure S shows the basic opera- 
tion of the program while Figure 6 provides more detail 
on the A/D conversion routine. These flow diagrams relate 
to the actual software shown in Figure 8. The hardware 
required for the data acquisition is shown in Figure 9; as 
can be seen, it is fairly simple, consisting of the MC 14433, 
MCI 403* reference, MCI 405 IB analog multiplexer, and 
an MC6820 PIA. The PIA is used as the interface between 
the microprocessor address and the data bus to the A/D. 
The microprocessor and associated memory are not shown 
due to a wide variety of forms possible depending upon 
the task that the total system is performing. 

The reference for the MC 14433 is an MC1403 bandgap 
reference which provides an output voltage of 2.5 volts. 
This voltage is divided down by the 20 kJ2 pot to the 2.000 
volt reference required by the MC14433. If a 200 mV 
reference is used, full scale for the DAN will be 199.9 mV. 

The analog multiplexing required to handle the eight 
input channels is provided by a MC14051B CMOS multi- 
plexer. This device selects one of eight inputs with a 3-bit 
binary code. The device is capable of switching dual 
polarity (plus or iniHits) with a sn#s pdan^ 

control voltage. 

•MC1403 to be introduced first quarter 1977. 



PIA FunctkMH 

The MCI 443 3 BCD output and digit select outputs are 
connected to the B side of the PIA as shown in lines 21-28 
of the software routine. These lines of Ike software are 
comment lines only and do not result in code for the 
microprocessor. The B side data register of the PIA is 
labeled throughout flie program as PIAIBD while the con- 
trol register is labeled PIAIBC. The control I/O lines 
(CBl and CB2) of the B side PIA are connected to EOC 
and DU of the MC 1433. 
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FIGURE 5 - Basic Operation of 8 Channel OAN 
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FIGURE 6 — A/D Conversion Subrotitine Flow Chart 

The first executable instruction for the program is in 
line 55 and starts a section called PIA assembly. The PIA 
sets the A side data register as all outputs and the B side 
data register as all inputs. From there the program goes to 
the main program simulation which, as its name implies, 
is a simulation of the user's main program. At such time 
in the user's program that some analog information is 
required, the A/D conversion subroutine starting in line 
75 is executed. This routine synchronizes the program 
mth the A/D converMon cycle md selects the first channel 
to be measured. 

After the A/D conversion cycle for the first channel is 
completed the microprocessor is interrupted by the EOC 
of the MC 14433. The interrupt program of line 88 is then 
executed; this demultiplexes the BCD output of the 
MCI 4433 and stores the data in memory. After completing 
the interrupt program the microprocessor returns to the 



A/D conversion subroutine and the next channel i$ 
selected. When the measurement of channel 2 is com- 
pleted, the interrupt program is then executed and the 
aisulting data stored aw^ay in memory. This procsedure is 
tepssted until all eight channels are read, after which the 
WO returns to the main program. At this point the data 
obtained in the A/D conversion subroutine may be pro- 
cessed as required. 

Looking at the software for the 8-channel data acquisi- 
tion network in more detail, program storage of the final 
results begins in memory location $0010. Each BCD 
character is stored in the four LSBs of these memory 
locations. See Figure 7 for explanation of data storage. 
Eaeh of the ei^t channel readings requires four memory 
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FIGURE 7 - Data Storage Definition 



locations with the MSD occupying the first of each 
mjasnce of four memcMy loeations. The index register is 
used to keep track of the next storage location for the 
BCD information. At the end of each channel's conversion 
Qtxle iitiex remitter pc^tsM^elfSD of iiat channel. 
This address is also stored at memory location called 
STORL. 

Memory location TEST has two putp<»^; the first is 
for keeping track of which WAl was executed when the 
MPU was in the interrupt routine. This is required since 
mote ixto one A/D com^Mon cycle is required for eaeh 
channel. For the first channel three EOC pulses are re- 
quired, while the remaining channels require only two 
i%/D <^vemda cyd^Sw' li&'ixfira hfB' conversion eySe^ to 
the first channel is used to synchronize the A/D converter 
to the MPU system. The second A/D conversion cycle in 
the first channel and the fkst conversion cyde of thft 
remaining channels ensure that the polarity is correct for 
the current input. This is required since the MCI 4433 
determines polarity in the previous conversion cycle. 

Since the display update pin is edge triggered it must 
be taken high and low again in each conversion cycle 
when the data is to read by the MPU. The DU pin is taken 
high prior to the WAX for the measurement and low in the 
interrupt routine after the EOC occurs. 

As mentioned previously, the multiplexed BCD data 
from the MCI 4433 is demultiplexed in the interrupt 
routine. A "1" is placed in bit 4 of POINTR which is 



compared with the contents of PIAIBD. Upon finding 
bSl in the true state, the lower four bits of PIAIBD 
(BCD data) are placed in the proper memory storage 
location, POINTR is then shifted to the left as each digit 
select occurs to look for the next successive digit select line. 

After all four digits are placed in memory the MSD is 
checked for overrange. If this condition occurs an $F1 is 
placed in the MSD for this channel. Otherwise the half 
digit and polarity are decoded. Memory location TEST is 
now used as a temporary storage location to decode the 
polarity. The half di^t is placed in the LSB of the MSD 
and negative polarity is in&ati^ by placing 9 "1" in the 
MSB of the MSD. 

The 8-channel DAN conversion tiifte is approximately 
320 ms with a 4QD kHz dodc ffecp^i# m iie MC14433. 



SAMPU; AND HOLD 

The dual ramp A/D conversion process requires that 
the input to the A/D remain constant during the conversion 
cycle. If it does not, a sample and hold circuit must be 
used to instire a c<msfant mpuf . 

SINGLE-CHANNEL DAN 

Figure 10 contains the software for a single-charmel 
DAN. The hardware wLQ be the same as Figure 8 except 
for the analog multiplexing. The program is the same 
except for the analog multiplexer control. 



FIGURE 8 — 8-Channel Data Acquisition Network 
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RESULTS STORED IN LDCflTIONS SOOl 0-$002F . 
ei=lCH CHANNEL □CCUPIES FOUR CONSECUTIVE 
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OVERRANGE INDICATION VIA AN "Fl" IN 
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FIGURE 8 — 8-Channel Data Acquisition Networic 
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FIGURE 9 — 8-Channel Data Acquisition Hardwara 
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FIQURE 10 — Single-Channel Data Acquisition Network 
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FIGURE 10 — Single-Channel Data Acquisition Network 
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